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A high speed modem (26) that transmits and receives digital data on an ensemble of carrier frequencies spanning the 
usable band of a dial-up telephone line (48). The modem includes a system (30, 32, 34, 36, 40, 43, 44) for variably allocating 
data and power among the carriers to compensate for equivalent noise and to maximize the data rate. Additionally, sys- 
tems for eliminating the need for an equalization network, for adaptively allocating control of a channel, and for tracking 
variations in line parameters are disclosed. 
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ENSEMBLE MODEM STRUCTURE FOR 
IMPERFECT TRANSMISSION MEDIA 



BACKGROUND OF THE INVENTION 

1. Field of the Invention ; 

The invention relates generally to the field 
of data conimunications and, more particularly, to a 
high speed modem* 

2. Description of the Prior Art ; 

Recently, specially designed telephone lines . 
for the direct transmission of digital data have been 
introduced. However, the vast majority of telephone 
lines are designed to carry analog voice frequency (VF) 
signals. Modems are utilized to modulate VF carrier 
signals to encode digital information on the VF carrier 
signals and to demodulate the signals to decode the 
digital information carried by the signal . 

Existing VF telephone lines have several 
limitations that degrade the performance of modems and 
limit the rate at which data can be transmitted below 
desired error rates- These limitations include the 
presence of frequency dependent noise on the VF tele- 
phone lines, a frequency dependent phase delay induced 
by the VF telephone lines, and frequency dependent sig- 
nal loss* 

Generally, the usable band of a VF telephone 
line is from slightly above zero to about four kHz. 
The power spectrum of the line noise is not uniformly 
distributed over frequency and is generally not deter- 
minative. Thus, there is no a priori method for deter- 
mining the distribution of the noise spectrum over the 
usable bandwidth of the VF line. 

Additionally, a frequency-dependent propaga- 
tion delay is induced by the VF telephone line. Thus, 
for a complex multi- frequency signal, a phase delay 
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between the various components of the signal will be 
induced by the VF telephone line* Again, this phase 
delay is not determinative and must be measured for an 
5 individual VF telephone line at the specific time that 
transmission takes place. 

Further, the signal loss over the VF 
telephone line varies with frequency. The equivalent 
noise is the noise spectrum component added to the 

10 signal loss component for each carrier frequency, where 
both components are measured in decibels (dB). 

Generally, prior art modems compensate for 
equivalent line noise and signal loss by gear- shifting' 
the data rate down to achieve a satisfactory error 

15 rate. For example, in U.S. patent 4,438,511, by Baran, 
a high speed modem designated SM9600 Super Modem 
manufactured by Gandalf Data, Inc., is described. In 
the presence of noise impairment, the SM9600 will "gear 
shift" or drop back its transmitted data rate to 4800 

20 bps or 2400 bps. The system described in the Baran 
patent transmits data over 64 orthogonally modulated 
carriers. The Baran system compensates for the frequency 
dependent nature of the noise on the VF line by termi- 
nating transmission on carriers having the same frequency 

25 as the frequency of large noise components on the line. 
Thus, Baran gracefully degrades its throughput by ceas- 
ing to transmit on carrier frequencies at the highest 
points of the VF line noise spectrum. The Baran system 
essentially makes a go/no go decision for each carrier 

30 signal, depending on the distribution of the VF line 
noise spectrum. This application reflects a continua- 
tion of the effort initiated by Baran. 

Most prior art systems compensate for fre- 
quency dependent phase delay induced by the VF line by 

35 an equalization system. The largest phase delay is 

induced in frequency components near the edges of the 
usable band. Accordingly, the frequency components 
near the center of the band are delayed to allow the 
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frequency components at the outside of the band to 
catch up. Equalization generally requires additional 
circuitry to accomplish the above-described delays. 
5 A further problem associated with two way 

transmission over the VF telephone line is that inter- 
ference between the outgoing and incoming signals is 
possible. Generally, separation and isolation between 
the two signals is achieved in one of three ways: 
10 (a) Frequency multiplexing in which different 

frequencies are used for the different signals. This 
method is common in modem-based telecommunication sys- 
tems. 

(b) Time multiplexing, in which, different 

15 time segments are used for the different signals. This 
method is often used in half-duplex systems in which a 
transmitter relinquishes a channel only after sending 
all the data it has. And, 

(c) Code multiplexing, in which the signals 
20 are sent using orthogonal codes. 

All of the above-described systems divide the 
space available according to constant proportions fixed 
during the initial system design. These constant 
proportions, however, may not be suitable to actual 
. 25 traffic load problem presented to each modem. For 

example, a clerk at a PC work station connected to a 
remote host computer may type ten or twenty characters 
and receive a full screen in return. In this case, 
constant proportions allocating the channel equally 

30 between the send and receive modems would greatly 

over allocate the channel to the PC work station clerk. 
Accordingly, a modem that allocates channel capacity 
according to the needs of the actual traffic load, 
situation would greatly increase the efficient 

35 utilization of the channel capacity. 



SUMMARY OF THE INVENTION 

The present invention is a high-speed modem 
for use with dial-up VF telephone lines. The modem 
utilizes a multicarrier modulation scheme and variably 
allocates data and power to the various carriers to 
maximize the overall data transmission rate. The 
allocation of power among the carriers is subject to 
the constraint that the total power allocated must not 
exceed a specified limit. 

In a preferred embodiment, the modem further 
includes a variable allocation system for sharing con- 
trol of a communication link between two modems (A and 
B) according to actual user requirements. 

Another aspect of the invention is a system 
for compensating for frequency dependent phase delay 
and preventing intersymbol interference that does not 
require an equalization network. 

According to one aspect of the invention, 
quadrature amplitude modulation (QAM) is utilized to 
encode data elements of varying complexity on each 
carrier. The equivalent noise component at each 
carrier frequency is measured over a communication link 
between two modems (A and B). 

As is known in the art, if the bit error rate 
(BER) is to be maintained t>elow a specified level, then 
the power required to transmit a data element of a 
given complexity on a given carrier frequency must be 
increased if the equivalent noise component at that 
frequency increases. Equivalently, to increase data 
complexity, the signal to noise ratio, S/N, must be 
increased. 

In one embodiment of the present invention, 
data and power are allocated to maximize the overall 
data rate within external BER and total available power 
constraints. The power allocation system computes the 
marginal required power to increase the symbol rate on 
each carrier from n to n + 1 information units. The 
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system then allocates information units to the carrier 
that requires the least additional power to increase 
its symbol rate by one information unit. Because the 
5 marginal powers are dependent on the values of the 

equivalent noise spectrum of the particular established 
transmission link, the allocation of power and data is 
specifically tailored to compensate for noise over this 
particular link. 

10 According to another aspect of the invention, 

a first section of the symbol on each carrier is 
retransmitted to form a guard- time waveform of duration 
T £ + Tp H where T E is the duration of the symbol and T pH 
is the duration of the first section. The, magnitude of 

15 Tp H is greater than or equal to the maximum estimated 

phase delay for any frequency component of the 

waveform. For example, if the symbol is represented by 

the time series, x Q — x n -l' transmitted * n time T £ ; 

then the guardtime waveform is represented by the time 

20 series, x n . * . x_ , x n ... x_ , transmitted in time 
0 n-l o m-l 

T E + t ph # The rat i° that m bears to n is equal to the 
ratio that T pH bears to T^. 

At the receiving modem, the. time of arrival, 
Tq , of the first frequency component of the guard- time 
25 waveform is determined. A sampling period, of dura- 
tion T £ , is initiated a tiime T Q + T p H - 

Accordingly, the entire symbol on each carrier 
frequency is sampled and intersymbol interference is 
eliminated. 

30 According to a still further aspect of the 

invention, allocation of control to the transmission 
link between modems A and B is accomplished by setting 
limits to the number of packets that each modem may 
transmit during one transmission cycle. A packet of 

35 information comprises the data encoded on the ensemble 

of carriers comprising one waveform. Each modem is also 
constrained to transmit a minimum number of packets to 
maintain the communication link between the modems. 
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Thus, even if one modem has no data to transmit, the 
minimum packets maintain timing and other parameters 
are transmitted- On the other hand, if the volume of 
5 data for a modem is large, it is constrained to transmit 
only the maximum limited number of packets, N, before 
relinquishing control to the other modem. 

In practice, if modem A has a small volume of 
data and modem B has a large volume of data, modem B 

10 will have control of the transmission link most of the 
time- If control is first allocated to modem A it will 
only transmit the minimal number, I, of packets. Thus 
A has control for only a short time. Control is then 
allocated to B which transmits N packets, where N may 

15 be very large. Control is again allocated to modem A 
which transmits I packets before returning control to 
B. 

Thus, allocation of control is proportional 
to the ratio of I to N. If the transmission of the 
20 volume of data on modem A requires L packets, where L 

is between I and N, then the allocation is proportional 
to the ratio of L to N. Accordingly, allocation of the 
transmission link varies according to the actual needs 
of the user. 

25 Additionally, the maximum number of packets, 

N, need not be the same fdr each modem, but may be 
varied to accommodate known disproportions in the data 
to be transmitted by A and B modems. 

According to another aspect of the invention, 

30 signal loss and frequency offset are measured prior to 
data determination. A tracking system determines 
variations from the measured values and compensates for * 
these deviations. 

According to a further aspect of the inven- 

35 tion, a system for determining a precise value of T Q 

is included. This system utilizes two timing signals, 
at f 1 and f 2 , incorporated in a waveform transmitted 
from modem A at time T, . The relative phase difference 
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between the first and second timing signals at time T A 
is zero. 

The waveform is received at modem B and a 
5 rough estimate, T EST , of the time of reception is 

obtained by detecting energy at f 1# The relative phase 
difference between the timing signals at time T EST is 
utilized to obtain a precise timing reference, T Q . 

BRIEF DESCRIPTION OF THE DRAWINGS 
10 Fig. 1 is a graph of the ensemble of carrier 

frequencies utilized in the present invention. 

Fig. 2 is a graph of the constellation illus- 
trating the QAM of each carrier. 

Fig. 3 is a block diagram of an embodiment of 
15 the invention. 

Fig. 4 is a flow chart illustrating the syn- 
chronization process of the present invention. 

Fig. 5 is a series of graphs depicting the 
constellations for 0, 2, 4, 5, 6 bit data elements and 
20 exemplary signal to noise ratios and power levels for 
each constellation. 

Fig. 6 is a graph illustrating the water fill- 
ing algorithm. 

Fig. 7 is a histogram illustrating the appli- 
25 cation of the waterfilling algorithm utilized in the 
present invention. 

Fig. 8 is a graph depicting the e£fects of 
phase dependent frequency delay on frequency components 
in the ensemble. 
30 Fig. 9 is a graph depicting the wave forms 

utilized in the present invention to prevent inter- 
symbol interference. 

Fig. 10 is a graph depicting the method of 
receiving the transmitted ensemble. 
35 Fig. 11 is a schematic diagram depicting the 

modulation template. 
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Fig. 12 is a schematic diagram depicting the 
quadrants of one square in the modulation template. 

Fig. 13 is a schematic diagram of a hardware 
5 embodiment of the present invention. 

DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS 
The present invention is a modem that 
adaptively allocates power between various carrier 
frequencies in a frequency ensemble to compensate for 

10 frequency dependent line noise, eliminates the need for 
equalization circuitry to compensate for a frequency 
dependent phase delay, and provides a duplex mechanism • 
that accounts for varying channel load conditions to 
allocate the channel between the send and receive 

15 modems. Additional features of the invention are de- 
scribed below, 

A brief description of the frequency ensemble 
and modulation scheme utilized in the present invention 
is first presented with respect to Figs. 1 and 2 to 

20 facilitate the understanding of the invention. A 

specific embodiment of the invention is then described 
with reference to Fig. 3. Finally, the operation of 
various features of the invention are described with 
reference to Figs. 4 through 13. 

25 Modulation and Ensemble Configuration 

Referring now to Fig. 1, a diagrammatic 
representation is shown of the transmit ensemble 10 of - 
the present invention. The ensemble includes 512 car- 
rier frequencies 12 equally spaced across the available 

30 4 kHz VF band. The present invention utilizes 

quadrature amplitude modulation (QAM) wherein phase 
independent sine and cosine signals at each carrier 
frequency are transmitted. The digital information 
transmitted at a given carrier frequency is encoded by 

35 amplitude modulating the independent sine and cosine 
signals at that frequency. 
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The QAM system transmits data at an overall 
bit rate, Rg. However, the transmission rate on each 
carrier, denoted the symbol or baud rate, R g , is only a 
5 fraction of R g . For example, if data were allocated 
equally between two carriers then R g = R B /2. 

In the preferred embodiment 0, 2, 4, 5 or 6 
bit data elements are encoded on each carrier and the 
modulation of each carrier is changed every 136 msec* 
10 A theoretical maximum, R g , assuming a 6 bit R g for each 
carrier, of 22,580 bit/sec (bps) results. A typical 
relizable R g , assuming 4 bit R g over 75% of the 
carriers, is equal to about 11,300 bps. This extremely 
high R s is achieved with a bit error rate of less than 
15 1 error/100,000 bits transmitted. 

In Fig. 1, a plurality of vertical lines 14 
separates each ensemble into time increments known 
hereafter as "epochs. 11 The epoch is of duration T E 
where the magnitude of T E is determined as set forth 
20 below. 

The QAM system for encoding digital data onto 
the various carrier frequencies will now be described 
with reference to Fig. 2. In Fig. 2 a four bit "con- 
stellation" 20 for the nth carrier is depicted. A four 

25 bit number may assume sixteen discrete values. Each 
point in the constellation represents a vector ( x n 'Y n ) 
with x n being the amplitude of the sine signal and y n 
being the amplitude of the cosine signal in"* the above- 
described QAM system. The subscript n indicates the 

30 carrier being modulated. Accordingly, the four bit 

constellation requires four discrete y n and four dis- 
crete x n values. As described more fully below, 
increased power is required to increase the number of 
bits transmitted at a given carrier frequency due to 

35 the equivalent noise component at that frequency. The 
receive modem, in the case of four bit transmission, 
must be able to discriminate between four possible 
values of the x R and y n amplitude coefficients. This 
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ability to discriminate is dependent on the signal to 
noise ratio for a given carrier frequency. 

In a preferred embodiment, packet technology 
5 is utilized to reduce the error rate* A packet includes 
the modulated epoch of carriers and error detection data* 
Each packet in error is retransmitted until correct. 
Alternatively, in systems where retransmission of data 
is undesirable, epochs with forward error correcting 

10 codes may be utilized* 

Block Diagram 
Fig. 3 is a block diagram of an embodiment of 
the present invention. The description that follows is 
of an originate modem 26 coupled to an originate end of 

15 a communication link formed over a public switched 

telephone line. It is understood that a communication 
system also includes an answer modem coupled to the 
answer end of the communication link. In the following 
discussion, parts in the answer modem corresponding to 

20 identical or similar parts in the originate modem will 
be designated by the reference number of the originate 
modem primed. 

Referring now to Fig. 3, an incoming data 
stream is received by a send system 28 of the modem 26 

25 at data input 30. The data is stored as a sequence of 
data bits in a buffer memory 32. The output of buffer 
memory 32 is coupled to the input of a modulation 
parameter generator 34. The output of the modulation - 
parameter generator 34 is coupled to a vector table 

30 buffer memory 36 with the vector table buffer memory 36 
also coupled to the input of a modulator 40. The out- 
put of the modulator 40 is coupled to a time sequence 
buffer 42 with the time sequence buffer 42 also coupled 
to the input of a digital-to-analog converter 43 in- 

35 eluded in an analog I/O interface 44. The interface 
44 couples the output of the modem to the public 
switched telephone lines 48. 
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A receive system 50 includes an analog-to- 
digital converter (ADC) 52 coupled to the public switched 
telephone line 48 and included in the interface 44. The 
5 output from the ADC 52 is coupled to a receive time 
series buffer 54 which is also coupled to the input of 
a demodulator 56. The output of the demodulator 56 is 
coupled to a receive vector table buffer 58 which is 
also coupled to the input of a digital data generator 

10 60. The digital data generator 60 has an output coupled 
to a receive data bit buffer 62 which is also coupled to 
an output terminal 64. 

A control and scheduling unit 66 is coupled 
with the modulation parameter generator 34, the vector 

15 table buffer 36, the demodulator 56, and the receive 
vector table buffer 58. 

An overview of the functioning of the embodi- 
ment depicted in Fig. 3 will now be presented. Prior 
to the transmission of data, the originate modem 26, in 

20 cooperation with the answer modem 26 1 , measures the equi- 
valent noise level at each carrier frequency, determines 
the number of bits per epoch to be transmitted on each 
carrier frequency, and allocates power to each carrier 
frequency as described more fully below. 

25 The incoming data is received at input port 

30 and formatted into a bit sequence stored in the 
input buffer 32. 

The modulator 34 encodes a given number of 
bits into an ( X n /Y n ) vector for each carrier frequency 

30 utilizing the QAM system described above. For example, 
if it were determined that four bits were to be trans- 
mitted at frequency f n then four bits from the bit 
stream would be converted to one of the sixteen points 
in the four bit constellation of Fig. 2. Each of these 

35 constellation points corresponds to one of sixteen pos- 
sible combinations of four bits. The amplitudes of the 
sine and cosine signals for frequency n then corresponds 
to the point in the constellation encoding the four bits 
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of the bit sequence. The (x n ,y n ) vectors are then 
stored in the vector buffer table 36. The modulator 
receives the table of (x n ,y n ) vectors for the carriers 
5 in the ensemble and generates a digitally encoded time 
series representing a wave form comprising the ensemble 
of QAM carrier frequencies . 

In a preferred embodiment the modulator 40 
includes a fast Fourier transform (FFT) and performs an 

10 inverse FFT operation utilizing the (x,y) vectors as 
the FFT coefficients. The vector table includes 1,024 
independent points representing the 1,024 FFT points of 
the 512 frequency constellation. The inverse FFT 
operation generates 1,024 points in a time series 

15 representing the QAM ensemble. The 1,024 elements of 
this digitally encoded time series are stored in the 
digital time series buffer 42. The digital time 
sequence is converted to an analog wave form by the 
analog to digital converter 43 and the interface 46 

20 conditions the signal for transmission over the public 
switched telephone lines 48. 

Turning now to the receive system 50 , the 
received analog waveform from the public switched tele- 
phone lines 48 is conditioned by the interface 46 and 

25 directed to the analog to digital converter 52. The 
analog to digital converter 52 converts the analog 
waveform to a digital 1,024 entry time series table 
which is stored in the receive time series buffer 54. 
The demodulator 56 converts the 1,024 entry time series 

30 table into a 512 entry (x n y ) vector table stored in 
the receive vector table buffer 58. This conversion is 
accomplished by performing an FFT on the time series. 
Note that information regarding the number of bits 
encoded onto each frequency carrier has been previously 

35 stored in the demodulator and digital data generator 60 
so that the (x,y) table stored in the receive vector 
table buffer 58 may be transformed to an output data 
bit sequence by the digital data generator 60. For 
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example, if the (x n ,y n ) vector represents a four bit 
sequence then this vector would be converted to a four 
bit sequence and stored in the receive data bit buffer 
5 62 by the digital data generator 60. The receive data 
bit sequence is then directed to the output 64 as an out- 
put data stream. 

A full description of the FFT techniques uti- 
lized is described in a book by Rabiner et al., entitled 

10 Theory and Applications of Digital Signal Processing , 

Prentice-Hall, Inc., N.J., 1975. However, the FFT modu- 
lation technique described above is not an integral part 
of the present invention. Alternatively, modulation " 
could be accomplished by direct multiplication of the 

15 carrier tones as described in the above-referenced Baran 
patent, which is hereby incorporated by reference, at 
col. 10, lines 13-70, and col. 11, lines 1-30. Addition- 
ally, the demodulation system described in Baran at col. 
12, lines 35-70, col. 13, lines 1-70, and col- 14, lines 

20 1-13 could be substituted. 

The control and scheduling unit 66 maintains 
overall supervision of the sequence of operations and 
controls input and output functions. 

Determination of Equivalent Noise 

25 As described above, the information content 

of the data element encoded on each frequency carrier 
and the power allocated to that frequency carrier 
depends on the magnitude of the channel noise component 
at that carrier frequency. The equivalent transmitted 

30 noise component at frequency f n , N(f n ), is the measured 
(received) noise power at frequency f multiplied by 
the measured signal loss at frequency f . The equiva- 
lent noise varies from line to line and also varies on 
a given line at different times. Accordingly, in the 

35 present system, N(f) is measured immediately prior to 
data transmission. 

The steps of a synchronization technique 
utilized in the present system to measure N(f) and 
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establish a transmission link between answer and ori- 
ginate modems 26 and 26 1 are illustrated in Fig. 4. 
Referring now to Fig. 4, in step 1 the originate modem 
5 dials the number of the answer modem and the answer 

modem goes off hook. In step 2 the answer modem trans- 
mits an epoch of two frequencies at the following power 
levels: 

(a) 1437.5 Hz. at -3 dBR; and 

10 (b) 1687.5 Hz at -3 dBR. 

The power is measured relative to a reference, R, where, 
in a preferred embodiment, OdBR = -9dBm, m being a milli- 
volt. These tones are used to determine timing and fre- 
quency offset as detailed subsequently. 

15 The answer modem then transmits an answer comb 

containing all 512 frequencies at -2 7 dBR. The originate 
modem receives the answer comb and performs an FFT on the 
comb. Since the power levels of the 512 frequencies were 
set at specified values, the control and scheduling unit 

20 66 answer modem 26 compares the (x n ,y ) values for each 
frequency of the received code and compares those values 
to a table of (x n ,y n ) values representing the power lev- 
els of the transmitted answer code. This comparison 
yields the signal loss at each frequency due to the 
.25 transmission over the VF telephone lines. 

During step 3 both the originate and answer 
modems 26 and 26 1 accumulate noise data present on the 
line in the absence of any transmission by either 
modem. Both modems then perform an FFT on the accumu- 

30 lated noise signals to determine the measured 

(received) noise spectrum component values at each 
carrier frequency. Several epochs of noise may be aver- 
aged to refine the measurement. 

In step 4 the originate modem transmits an 

35 epoch of two frequencies followed by an originate comb 
of 512 frequencies with the same power levels described 
above for step 2. The answer modem receives the epoch 
and the originate comb and calculates the timing, fre- 
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guency offset and signal loss values at each carrier 
freguency as described above for the originate modem in 
step 2. At this point the originate modem 26 has accum- 
5 ulated noise and signal loss data for transmission in 
the answer originate direction while the answer modem 
has accumulated the same data relating to transmission 
in the originate answer direction. Each modem reguires 
data relating to transmission loss and receive noise in 

10 both the originate-answer and answer-originate direc- 
tions. Therefore, this data is exchanged between the 
two modems according to the remaining steps of the syn- 
chronization process. 

In step 5 the originate modem generates and 

15 transmits a first phase encoded signal indicating which 
carrier frequencies will support two bit transmission 
at standard power levels in the answer-originate direc- 
tion. Each component that will support two bits in the 
answer-originate direction at a standard power level is 

20 generated as a -28 dBR signal with 180° relative phase. 
Each component that will not support two bit transmis- 
sion in the answer-originate direction at the standard 
power level is coded as a -28 dBR,0° relative phase 
signal. The answer modem receives this signal and 

25 determines which freguency carriers will support two 
bit transmission in the answer-originate direction. * 

In step 6 the answer modem generates and 
transmits a second phase encoded signal indicating 
which carrier frequencies will support two bit trans- 

30 mission in both the originate-answer and answer-origi- 
nate directions. The generation of this signal is 
possible because the answer modem has accumulated noise 
and signal loss data in the originate-answer direction 
and has received the same data for the answer-originate 

35 direction in the signal generated by the originate 

modem in step 5. In the signal generated by the origi- 
nate modem, each frequency component that will support 
two bits in both directions is coded with 180° relative 
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tive phase. 

A transmission link now exists between the 
5 two modems. In general, 300 to 400 frequency compo- 
nents will support two bit transmission at a standard 
power level, thereby establishing about a 600 bit/epoch 
rate between the two modems. In step 7 the originate 
modem sends data on the number of bits (0 to 15) and 

10 the power levels (0 to 63dB) that can be supported on 
each frequency in the answer-originate direction in 
ensemble packets formed over this existing data link. 
Accordingly, both the originate and answer modem now 
have the data relating to transmission in the answer- 

15 originate direction. The steps for calculating the 
number of bits and power levels that can be supported 
on each frequency component will be described below. 

In step 8 the answer modem sends data on the 
number of bits and power levels that can be supported 

20 on each frequency in the originate- answer direction 
utilizing the existing data link. Thus, both modems 
are apprised of the number of bits and power levels to 
be supported on each frequency component in both the 
answer-originate and originate- answer directions. 

25 The above description of the determination of 

the equivalent noise level? component at each carrier - 
frequency sets forth the required steps in a given 
sequence. However, the sequence of steps is"^ not criti- 
cal and many of the steps may be done simultaneously or 

30 in different order, for example, the performance of the 
FFT on the originate code and the accumulation of noise 
data may be done simultaneously. A precise timing 
reference is also calculated during the synchronization 
process. The calculation of this timing reference will 

35 be described more fully below after the description of 
the method for calculating the number of bits and power 
levels allocated to each frequency component. 
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It is a common VF telephone line impairment 
that a frequency offset, of up to 7 Hz, exists between 
transmitted and received signals. This offset must be 
5 corrected for the FFT to function reliably. In a 
preferred embodiment, this correction is achieved by 
performing a single sideband modulation of the quadra- 
ture tones at the offset frequency by the true and Hil- 
bert images of received signal. Synchronization and 

10 tracking algorithms generate estimates of the frequency 
offset necessary. 

Power and Code Complexity Allocation 
The information encoded on each carrier fre- 
quency signal is decoded at the receiver channel by the 

15 demodulator 56. Channel noise distorts the transmitted 
signal and degrades the accuracy of the demodulation 
process. The transmission of a data element having a 
specified complexity, e.g., B Q bits at a specified fre- 
quency, f Q , over a VF telephone line characterized by 

20 an equivalent noise level component, N Q , will now be 
analyzed. Generally, external system requirements 
determine a maximum bit error rate (BER) that can be 
tolerated. For the transmission of b Q bits at noise 
level N Q and frequency f Q , the signal to noise ratio 

25 must exceed E^/Nq where E fa is the signal power per bit 
to maintain the BER below ^a given BER, (BER) Q . 

Fig. 5 depicts the QAM constellations for 
signals of various complexities B. An exemplary signal 
to noise ratio, E^/Nq, for each constellation and the 

30 power required to transmit the number of bits in the 
constellation without exceeding (BER) Q is depicted 
alongside each constellation graph. 

A modem operates under the constraint that 
the total available power placed on the public switched 

35 telephone lines may not exceed a value, P Q , set by the 
telephone companies and government agencies. Thus, 
signal power may not be increased indefinitely to 
compensate for line noise. Accordingly, as noise 
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increases, the complexity of the signals transmitted 
must be decreased to maintain the required BER. 

Most existing modems arbitrarily gear shift 
5 the signal complexity down as line noise power 

increases. For example, one prior art modem reduces 
the transmitted data rate from a maximum of 9,600 bps 
to steps of 7/200 bps, 4,800 bps, 2,400 bps, 1,200 bps, 
and so on until the bit error rate is reduced below a 

10 specified maximum. Accordingly, the signal rate is 
decreased in large steps to compensate for noise. In 
the Baran patent, the method for reducing the trans- 
mission rate takes into account the frequency dependent 
nature of the noise spectrum. There, each channel 

15 carries a preset number of bits at a specified power 
level* The noise component at each frequency is 
measured and a decision is made whether to transmit at 
each carrier frequency. Thus, in Baran, the data rate 
reduction scheme compensates for the actual distribu- 

20 tion of the noise over the available bandwidth. 

In the present invention, the complexity of 
the signal on each frequency carrier and the amount of 
the available power allocated to each frequency carrier 
is varied in response to the frequency dependence of 

25 the line noise spectrum. 

The present system for assigning various code 
complexities and power levels to the frequency component 
signals in the ensemble is based on the waterfilling 
algorithm. The waterfilling algorithm is an informa- 

30 tion theoretic way of assigning power to a channel to 
maximize the flow of information across the channel. 
The channel is of the type characterized by an uneven 
noise distribution and the transmitter is subject to a 
power constraint. Fig. 6 provides a visualization of 

35 the waterfilling algorithm. Referring now to Fig. 6, 

power is measured along the vertical axis and frequency 
is measured along the horizontal axis. The equivalent 
noise spectrum is represented by the solid line 70 and 
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the available power is represented by the area of the 
cross hatched region 72. The name waterfilling comes 
from the analogy of the equivalent noise function to a 
5 series of valleys in a mountain filled with a volume of 
water representing the assigned power. The water fills 
the valleys and assumes a level surface. A theoretical 
description of the waterfilling algorithm is given in 
the book by Gallagher, entitled Information Theory And 

10 Reliable Communication ; J. Wiley and Sons, New York, 
1968, p. 387. 

It must be emphasized that the waterfilling 
theorem relates to maximizing the theoretical capacity 
of a channel where the capacity is defined as the maxi- 

15 mum of all data rates achievable using different codes, 
all of which are error correcting, and where the best 
tend to be of infinite length. 

The method utilizing the present invention 
does not maximize the capacity of the channel. Instead, 

20 the method maximizes the amount of information trans- 
mitted utilizing the QAM ensemble described above with 
respect to Fig. 1 and subject to an available power 
restriction. 

An implementation of the waterfilling concept 

25 is to allocate an increment of available power to the 
carrier having the lowest equivalent noise floor until 
the allocatd power level reaches the equivalent noise 
level of the second lowest carrier. This allocation 
requires a scan through the 512 frequencies. 

30 Incremental power is then allocated between 

the lowest two carriers until the equivalent noise 
level of the third lowest channel is reached. This 
allocation level requires many scans through the 
frequency table and is computationally complex. 

35 The power allocation method used in a pre- 

ferred embodiment of the present invention is as 
follows : 
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(1) Calculate the system noise at the trans- 
mitter by measuring the equivalent noise at the 
receiver and multiplying by transmission loss. This 

5 process for measuring these quantities was described 
above with respect to synchronization and Fig. 4. The 
system noise components are calculated for each carrier 
frequency. 

(2) For each carrier frequency, calculate 
10 the power levels required to transmit data elements of 

varying complexity (in the present case, 0, 2, 4, 5, 6, 
and 8 bits)- This is accomplished by multiplying the 
equivalent noise by the signal to noise ratios neces- 
sary for transmission of the various data elements with 

15 a required BER, for example one error per 100,000 bits. 
The overall BER is the sum of the signal error rates of 
each modulated carrier. These signal to noise ratios 
are available from standard references, and are well- 
known in the art. 

20 (3) From the calculated required transmission 

power levels, the marginal required power levels to in- 
crease data element complexity are determined. These 
marginal required power levels are the difference in 
transmission power divided by the quantitative differ- 

25 ence in complexity of the data elements closest in com- 
plexity. 

(4) For each channel generate a two column 
table of marginal required power levels and "quantita- 
tive differences where the units are typically ex- 

30 pressed as Watts and bits, respectively. 

(5) Construct a histogram by organizing the 
table of step 4 according to increasing marginal power. 

(6) Assign the available transmitter power 
sequentially over the increasing marginal powers until 

35 available power is exhausted. 

The power allocation method may be better 
understood through a simple example. The numbers pre- 
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sented in the example are not intended to represent 
parameters encountered in an operating system. 

Table 1 sets out the power requirement, P, to 
transmit a data element of a selected number of bits, 
N 1# for two carriers A and B at frequencies f A and fg. 



10 



N ] 

0 
2 
4 
5 
6 



N 2 -N x 



2 
2 
1 
1 



TABLE 1 
Carrier A 

P 

0 

4 
12 
19 
29 



MP(N^ to N 2 ) 

MP(0to2)=2/bit 
MP(2to4)=4/bit 
MP(4to5)=7/bit 
MP(5to6)=10/bit 



15 



20 



N 3 
0 

2 

4 

5 

6 



N 2" N 1 



2 
2 
1 
1 



Carrier B 

P 

0 

6 
18 
29 
44 



MP(N 1 to N 2 ) 

MP(0to2)=3/bit 
MP(2to4)=6/bit 
MP(4to5)=ll/bit 
MP(5to6)=15/bit 



The marginal power to increase the complexity 
from a first number of bits, N^, to a second number of 
bits, N 2 , is defined by the relationship: 



25 



MP(N, 



to N 2 ) = 



P 2 - P l 
N 2 - N x 



30 



where P 2 and P 1 are the powers required to transmit 
data elements of complexity N 2 and ^ 2 " N 1 is 

quantitative difference in the complexity of the data 
elements. It is understood the BER is constrained to 
remain below a preset limit. 
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The marginal powers for f A are less than for 
f B because the equivalent noise at fg, N ( f B^' is 
greater than the equivalent noise at f ft , N(f A ). 
5 The implementation of the allocation scheme 

for carriers A and B will now be described. Assume that 
a total number of bits, N T , are encoded on the ensemble 
but that no bits have been assigned to carriers A or B. 
For example, »(f A ) and N(f A ) might be greater than the 

10 powers of those carriers already carrying the data. 

In this example, the system is to allocate 
ten remaining available power units between carriers A 
and B to increase the overall data element complexity 
by the maximum amount. 

15 To increase N T by two bits requires that four 

units of power be allocated if channel A is utilized 
and that six units of power be allocated in channel B 
is utilized. This follows because for both channels 
N x = 0 and N 2 = 2 and MP(0 to 2) - 2/bit for channel A 

20 and MP(0 to 2) = 3/bit for channel B. Therefore, the 
system allocates four units of power to carrier A, en- 
codes a two bit data element on carrier A, increases the 
overall signal complexity from N T to N T + 2 f and has six 
remaining available power units. 

25 The next increase of two bits requires six 

power units because MP(2 to 4) = 4/bit for carrier A and 
MP(0 to 2) = 3/bit for channel B. Therefore, the system 
allocates six units of power to carrier B, encodes a 
two bit data element on carrier B, increases the over- 

30 all signal complexity from N T + 2 to N T + 4 bits, and 
has no remaining available power units. 

As is now clear, the system "shops" among the 
various carrier frequencies for the lowest power cost 
to increase the complexity of the overall ensemble data 

35 element. 

The allocation system is extended to the full 
512 carrier ensemble by first generating the tables of 
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Table 1 for each carrier during a first pass through 
the frequencies. 

A histogram organizing the calculated 
5 marginal required power levels for all the carriers 
according to increasing power is then constructed. 
Fig. 7 is a depiction of an exemplary histogram 
constructed according to the present method. 

In Fig. 7 the entire table of marginal powers 

10 is not displayed. Instead, the histogram is 

constructed having a range of 64dB with counts spaced 
in 0.5dB steps* The quantitative differences between 
the steps are utilized as counts. Although this 
approach results in a slight round-off error, a 

15 significant reduction in task length is achieved. The 
method used to construct the histogram is not critical 
to practicing the invention. 

Each count of the histogram has an integer 
entry representing the number of carriers having a 

20 marginal power value equal to the power value at the 

count. The histogram is scanned from the lowest power 
level. The integer entry at each count is multiplied 
by the number of counts and subtracted from the avail- 
able power. The scan continues until available power 

25 is exhausted. 

When the scan is completed it has been deter- 
mined that all marginal power values below a given 
level, MP (max) , are acceptable for power ancl data allo- 
cation. Additionally, if available power is exhausted 

30 partially through marginal power level, MP(max), then k 
additional carriers will be allocated power equal to 
MP(max + 1). 

The system then scans through the ensemble 
again to allocate power and data to the various car- 

35 riers. The amount of power allocated to each carrier 
is the sum of marginal power values for that carrier 
less than or equal to MP (max). Additionally, an amount 
of power equal to MP (max + 1) will be allocated if the 
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k MP (max + 1) values have not been previously 
allocated* 

Timing and Phase Delay Compensation 
5 The reconstruction of (x,y) vector table by 

the receive system requires 1024 time samples of the 
received waveform. The bandwidth is about 4kHz so that 
Nyguist sampling rate about 8000/sec and the time sample 
offset between samples is 1*25 microseconds. The total 
10 sampling time is thus 128 msec. Similarly, the transmit 
FFT generates a time series having 1024 entries and the 
symbol time is 128 msec. 

The sampling process requires a timing refer- 
ence to initiate the sampling. This timing reference 
15 is established during synchronization by the following 
method: 

During the synchronization steps defined with 
reference to Fig. 4, the originate modem detects energy 
at the 1437.5 Hz frequency component (the first timing 
20 signal) in the answer comb at time T EST * This time is a 
rough measure of the precise time that the first timing 
frequency component arrives at the receiver and is 
generally accurate to about 2 msec. 

This rough measure is refined by the follow- 
25 ing steps. The first timing signal and a second timing 
signal (at 1687,5 Hz) are transmitted with zero rela- 
tive phase at the epoch mark. 

The originate modem compares the phases of 
the first and second timing signals at time T„ crp . The 

bo J. 

30 250 Hz frequency difference between the first and 
second timing signals results in an 11° phase shift 
between the two signals for each 125 microsecond time 
sample offset. The first and second timing signals 
have low relative phase distortion (less than 250 

35 microseconds) due to their location near the center of 
the band. Accordingly, by comparing the phases of the 
two timing samples and correcting T pc , T by the number of 
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time sampling offsets indicated by the phase difference, 
a precise timing reference, T Q , can be determined. 

A further difficulty relating to timing the 
5 sampling process relates to frequency dependent phase 
delay induced by the VF line. This phase delay 
typically is on the order of 2 msec, or more, for VF 
telephone lines. Further, this phase delay is signi- 
ficantly worse near the edges of the 4kHz usable band. 

10 Fig. 8 depicts distribution of the frequency 

carriers of the ensemble after undergoing frequency 
dependent phase delay. Referring to Fig. 8 f three 
signals 90, 92, and 94 at frequencies f Q , f 255 r and 
f 512 are de P icted - Two symbols, x^ and y^, of length 

15 T s are transmitted at each frequency. Note that the 
duration of each symbol is not changed. However, the 
leading edge of the signals near the edge of the band 
92 and 94 are delayed relative to those signals near 
the center of the band 94. 

20 Additionally, for two sequentially transmit- 

ted epochs x^ and y i the trailing section of the first 
symbol x^ on signals 92 and 96, near the outer edge of 
the band will overlap the leading edge of the second 
symbol y^ on the signal 94 near the center of the band. 

25 This overlap results in intersymbol interference. 

If the sampling interval is framed to sample 
a given time interval, T g/ then complete samples of 
every carrier in the ensemble will not be obtained and 
signals from other epochs will also be sampled. 

30 Existing systems utilize phase correction 

(equalization) networks to correct for phase distortion 
and to prevent intersymbol interference. 

The present invention utilizes a unique 
guard-time format to eliminate the need for an equali- 

35 zation network. This format is illustrated in Fig. 9. 

Referring now to Fig. 9, first, second, and 
third transmitted symbols, represented by time series 
x i' y i' and 2 i' res P ect i ve lY/ depicted. The wave- 
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forms depicted in Fig- 3 are modulated on one of the 
carriers at frequency f . In this example a symbol 
time, Tg, of 128 msec, and a maximum phase delay, T pH , 
5 of 8 msec are assumed. A guard- time waveform is formed 
by repeating the first 8 msec, of the symbol. The 
guard- time waveform defines an epoch of 136 msec. For 
example, in the first waveform 110, (X i ), the time 
series of the symbol, X Q - X 1023 , is first transmitted, 
10 then the first 8 msec, of the symbol, X Q - X 63 , are 
repeated. 

The sampling of the epoch is aligned with the 
last 128 msec, of the guard- time waveform (relative to 
the beginning of the guard-time epoch defined by those 

15 frequency components which arrive first). 

This detection process is illustrated in Fig. 
10. In Fig. 10 first and second guard- time waveforms 
110 and 112 at f 1# near the center of the band, and f 2 , 
near the edge of the band, are depicted. The frequency 

20 component at f-^ is the component of the ensemble that 
arrives first at the receiver and the component at f 2 
arrives last. In Fig. 10 the second waveform 112, at 
f 2 , arrives at the receiver at T Q + T pH , which is 8 msec, 
after the time, T Q , that the first waveform 110, at f^, 

25 arrives at the receiver. The sampling period of 128 

msec, is initiated at the time T Q + t ph* Thus, the en- 
tire symbol on f 2 , X Q - X 1023 , is sampled. The entire 
symbol at f^ is also sampled because the initial 8 
msec, of that symbol has been retransmitted. 

30 Also, intersymbol interference has been 

eliminated. The arrival of the second symbol, (y^), at 

has been delayed 8 msec, by the retransmission of 
the first 8 msec, of (x-). Thus, the leading edge of 
the second symbol at f^, does not overlap the trailing 

35 edge of the first symbol at f 2 . 

The 8 msec, guardtime reduces the usable time- 
bandwidth product of the system by only about 6%. This 
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small decrease is due to the very long duration of each 
symbol relative to the necessary guardtime. 

Tracking 

5 In practice, for a given carrier, the mag- 

nitudes of the (x,y) vectors extracted during the 
demodulation process do not fall exactly at the 
constellation points but are distributed over a range 
about each point due to noise and other factors . 

10 Accordingly, the signal is decoded utilizing a modu- 
lation template as depicted in Fig. 11. 

.Referring now to Fig. 11, the template is 
formed by a grid of squares 113 with the constellation 
points 114 at the centers of the squares 113. 

15 In Fig. 11, the vector W = (x n ,y n ) represents 

the demodulated amplitudes of the sine and cosine signals 
at f n - W is in the square 113 having the constellation 
point (3,3) centered therein. Accordingly, W is 
decoded as (3,3) . 

20 The present invention includes a system for 

tracking to determine changes in transmission loss, 
frequency offset, and timing from the values determined 
during synchronization. 

This tracking system utilizes the position of 

25 the received vectors in the squares of the demodulation 
template of Fig. 11. In Fig. 12, a single square is 
divided into four quadrants upper left, lower right, 
upper right, lower right, 115, 116, 117, and 118 char- 
acterized as too fast, too slow, too big, and too little, 

30 respectively. If counts in all four quadrants over time 
by frequency or over frequency at one time are equal or 
nearly equal then the system is in alignment. That is, 
if noise is the only impairment, then the direction of 
error for the decoded vector, W, should be random. 

35 However, if transmission loss changes by even 

O.ldB the number of too small counts will vary signifi- 
cantly from the number of too large counts. Similarly, 
a large difference between the number of too fast and 
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too slow counts indicates a phase rotation caused by a 
change in the offset frequency. Thus, the differences 
between the too fast, too slow, and too big, too small 
5 counts is an error characteristic that tracks varia- 
tions in signal loss and offset frequency. 

The present invention utilizes this error 
characteristic to adjust the signal loss and frequency 
offset determined during synchronization. For each 

10 frequency an adjustment of ± .ldB or ± 1.0° is made 

depending on the error characteristic. Other divisions 
of the decoding region into distinct or overlapping sub- 
regions characterized as too fast, too slow, too big, 
and too little are preferred in some embodiments. 

15 Additionally, the phase of the timing signals 

is tracked to allow corrections of T Q . 

Allocation of Channel Control 
The present invention further includes a 
unique system for allocating control of an established 

20 communication link between the originate and answer 

modems (hereinafter designated A and B, respectively). 
Each waveform comprising the encoded ensemble of fre- 
quencies forms a packet of information. 

Control of the transmission link is first 

25 allocated to modem A. Modem A then determines the 
volume of data in its input buffer and transmits 
between I (a minimum) and N (a previously determined 
maximum) packets of data as appropriate. The predeter- 
mined number N serves as a limit and the end number of 

30 transmitted packets may be significantly less than 

required to empty the input buffer. On the other hand, 
if modem A has little or no data in its input buffer it 
will still transmit I packets of information to maintain 
communication with modem B. For example, the I packets 

35 may comprise the originate or answer comb of frequencies 
defined above with respect to Fig. 4 and the synchroni- 
zation process. 
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Control of the communication link is then 
allocated to modem B which repeats the actions of modem 
A. Of course, if modem B transmits the minimum num- 
5 ber,I, of packets it is confirming to modem A the 
vitality of modem B. 

There is no need for the limits N on the two 
modems to be the same, or to restrict them from being 
adaptable under modem control to obtain rapid character 
10 echo or other user oriented goals* 

Hardware Implementation 
Fig. 13 is a block diagram of a hardware 
embodiment of the invention. Referring now to Fig. 13, 
an electronic digital processor 120, an analog I/O 
15 interface 44, and a digital I/O interface 122 are 
coupled to a common data bus 124. The analog I/O 
interface 44 interfaces the public switched telephone 
line 48 with the common data bus 124 and the digital 
interface 122 interfaces digital terminal equipment 126 
20 with the common data bus 124. 

The following components are utilized in a 
preferred embodiment of the invention. The analog I/O 
interface 44 is a high performance 12 bit coder-decoder 
(codec) and telephone line interface. The interface has 
25 access to RAM 132 and is controlled by supervisory micro- 
processor 128. The codec is a single chip combination 
of an analog to digital converter, a digital to analog 
converter, and several band pass filters. 

The digital I/O interface 122 is a standard 
30 RS-232 serial interface to a standard twenty-five pin 
RS-232 type connector or a parallel interface to a per- 
sonal computer bus. 

The electronic digital processor 120, includes 
a supervisory processor 128 , a general purpose mathema- 
35 tical processor 130, a 32K by 16 bit shared RAM sub- 
system 132, and a read only memory (ROM) unit 133, 
coupled to an address bus 135. 
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The supervisory microprocessor 128 is a 68000 
data processor subsystem including a 10MHz 68000 pro- 
cessor and the 68000 program memory- The 32K by 16 
5 bit program memory consists of several low power, high 
density, ROM chips included in the ROM unit 133. 

The mathematical processor 130 is a 320 digi- 
tal signal microprocessor system (DSP) including a 
20MHz 320 processor, the 320 program memory, and an 

10 interface to the shared RAM system. Two high speed ROM 
chips, included in ROM unit 133, comprise the 8192 x 16 
bit program memory. 

The 320 system program memory includes pro- 
grams for performing the modulation table look-up, FFT, 

15 demodulation, and other operations described above* 

The 68000 processor handles digital data streams at the 
input and output, performs tasking to and supervision 
of the 320 signal processor and associated analog I/O, 
and performs self and system test as appropriate* 

20 The invention has been explained with respect 

to specific embodiments. Other embodiments will now be 
apparent to those of ordinary skill in the art. 

In particular, the ensemble of carrier fre- 
quencies need not be limited as above-described. The 

25 number of carriers may be any power of 2, e.g. 1024, or 
some arbitrary number. Additionally, the frequencies 
need not be evenly spaced over the entire VF band. 
Further, the QAM scheme is not critical to practicing 
the invention. For example, AM could be utilized 

30 although the data rate, R g , would be reduced. 

Still further, the modulation template need 
not be comprised of squares. Arbitrarily shaped 
regions surrounding the constellation points may be 
defined. The tracking system was described where the 

35 squares in the modulation template were divided into 
four quadrants. However, a given parameter may be 
tracked by tracking the difference in the number of 
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counts in arbitrary regions defined about a 
constellation point* 

Still further, a hardware embodiment 
5 including a supervisory microprocessor and a general 
purpose mathematical processor has been described. 
However, different combinations of IC chips may be 
utilized. For example, a dedicated FFT chip could be 
utilized to perform modulation and demodulation 
10 operations. 

Still further, the information units utilized 
in the above description were bits. However, the 
invention is not limited to binary system. 

Accordingly, it is therefore intended that 
15 the invention can be limited except as indicated by the 
appended claims. 



WO 86/07223 



PCT/US86/00983 



32 

WHAT IS CLAIMED IS : 

1. In a high speed modem, for transmitting 
data over a telephone line, of the type that encodes 

5 data elements on an ensemble of carrier frequencies, a 
method for allocating data and power to the carrier 
frequencies, said method comprising the steps of: 

determining the equivalent noise component 
for every carrier frequency in the ensemble; 
10 determining the marginal power requirement to 

increase the complexity of the data element on each 
carrier from n information units to n + 1 information 
units, n being an integer between 0 and N; 

ordering the marginal powers of all the car- 
15 riers in the ensemble in order of increasing power; 

assigning available power to the ordered mar- 
ginal powers in order of increasing power; 

determining the value, MP (max) at which point 
the available power is exhausted; and 
20 allocating power and data to each carrier 

frequency where the power allocated is equal to the sum 
of all the marginal powers less than or equal to MP (max) 
for that carrier and the number of data units allocated 
is equal to the number of marginal powers for that car- 
25 rier less than or equal to MP(max). 

2 , The invention of claim 1 where said step 
of ordering comprises the steps of: 

providing a table of arbitrary marginal power 
levels; and 

30 rounding the value of each determined marginal 

power level to one of the values of the table of arbi- 
trary marginal power levels to decrease computational 
complexity. 
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3. The invention of claim 2 wherein the 
step of determining equivalent noise comprises the steps 
of: 

5 providing an A and a B modem interconnected 

by a telephone line; 

establishing a communication link between 
said A and B modems; 

accumulating line noise data during a no trans - 
10 mission time interval at said A and B modems; 

transmitting at least a first ensemble of 
frequency carriers from said A modem to said B modem, 
where the amplitude of each carrier has a predetermined 
value; 

15 receiving said first ensemble at said B modem; 

measuring the amplitude of each carrier re- 
ceived at said B modem; 

comparing the measured amplitudes at said B 
modem with said predetermined amplitudes to determine 
20 signal loss, in dB, at each carrier frequency; 

determining the value of the component, in 
dB, at each carrier frequency of the accumulated noise; 
and 

adding the signal loss at each carrier fre- 
25 quency to the noise component at each carrier frequency 
to determine equivalent noise . 

4. A high speed modem of the type for trans- 
mitting a signal on a VF telephone line, comprising: 

means for receiving an input digital data 
30 stream and for storing said input digital data; 

means for generating a modulated ensemble of 
carriers to encode said input digital data, where each 
carrier has data elements of variable complexity encoded 
thereon; 

35 means for measuring the signal loss and noise 

loss of the VF telephone line for each carrier; and 
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means for varying the complexity of the data 
element encoded on each carrier and the amount of power 
allocated to each carrier to compensate for the measured 
5 signal loss and noise level, 

5. A high speed modem of the type that en- 
codes data elements on an ensemble of carriers of dif- 
ferent frequency, said modem comprising: 

a digital electronic processor; 
10 a digital electronic memory; 

bus means for coupling said processor and 
said memory; 

means, associated with said digital electronic 
processor, for 

15 determining the equivalent noise component 

for every carrier frequency in the ensemble; 

determining the marginal power requirements 
to increase the complexity of the data element on each 
carrier from n information units to n + 1 information 
20 units, n being an integer between 0 and N; 

ordering the marginal powers of all the car- 
riers in the ensemble in order of increasing power; 

assigning available power to the ordered mar- 
ginal powers in order of increasing power; 
25 determining the value, MP (max) at which point 

the available power is exhausted; and 

assigning power and data to each carrier fre- 
quency where the power assigned is equal to the sum of 
all the marginal powers less than or equal to MP(max) 
30 for that carrier and the number of data units is equal 
to the number of marginal powers for that carrier less 
than or equal to MP (max) . 

6. In a high speed modem, for transmitting 
data in the form of a QAM ensemble of carrier frequen- 

35 cies on a VF telephone line, of the type that measures 
the magnitude of a system parameter prior to 
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transmission, a method for tracking deviations in the 
magnitude of the system parameter during the receipt of 
data, said method comprising the steps of: 
5 generating QAM constellations for a plurality 

of carrier frequencies; 

constructing a demodulation template for one 
of said plurality of carrier frequencies comprising a 
plurality of first regions with one of the points of 
10 said constellation positioned within each of said first 
regions ; 

forming a set of tracking regions where each 

first region has a first and second tracking region 

disposed therein; 
15 demodulating said ensemble of carriers to 

obtain the demodulation points positioned in said set 

of first and second tracking regions; 

counting the number of points disposed in 

said set of first tracking regions and the number of 
20 points disposed in said set of second tracking regions; 

determining the difference in the number of 

counts disposed in said set of first tracking regions 

and disposed in said tracking regions to construct an 

error characteristic; and 
25 utilizing said error characteristic to adjust 

the magnitude of said signal parameter during the receipt 

of data.. 

7. The invention of claim 6 wherein said 
step of constructing a demodulation template comprises 
30 the step of: 

constraining said first regions to be in the 
shape of squares having said constellation points cen- 
tered therein. 
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8. The invention of claim 7 wherein said 
step of forming said tracking regions comprises the 
step of: 
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dividing said squares into quadrants; and 
selecting said tracking regions to be symmetri- 
cally disposed quadrants* 

5 9. In a communication system of the type 

including two modems (A and B) coupled by a transmis- 
sion link, each modem having an input buffer for storing 
data to be transmitted, a method for allocating control 
of the transmission link between modem A and B compris- 
10 ing the steps of: 

allocating control of the transmission 
link to modem A; 

determining the volume of data stored in 
the input buffer of modem A; 
15 determining the number ,K, of packets of 

data required to transmit the volume of data stored in 
the input buffer of modem A; 

transmitting L packets of data from modem 
A to modem B where L is equal to I if K is less than 
20 1^, where L is equal to K if K is greater than or equal 
to I A , and where L is equal to N A if K is greater than 
N A so that the minimum number of packets transmitted is 
I A and the maximum is N A ; 

allocating control of the transmission 
25 link to modem B; 

determining the volume of data in the 
input buffer of modem B; 

determining the number, J, of packets of 
data required to transmit the volume of data stored in 
30 the input buffer of modem B; 

transmitting M packets of data from modem 
B to modem A where M is equal to I g if J is less than 
I B , where M is equal to J if J is greater than or equal 
to I B , and where L is equal to N B if J is greater than 
35 N B so that the minimum number of packets transmitted is 
I B and the maximum is N fi ; 



37 



where allocation of control between modem 
A and B is dependent on the volume of data stored in 
the input buffers of modems A and B. 

10. In a high speed modem, for transmitting 
data over a telephone line, of the type that encodes 
data elements on an ensemble of carrier frequencies, a 
system for allocating data and power to the carrier 
frequencies, said system comprising: 

means for determining the equivalent noise 
component for every carrier frequency in the ensemble; 

means for determining the marginal power re- 
quirement to increase the complexity of the data ele- 
ment on each carrier from n information units to n + 1 
information units, n being an integer between 0 and N; 

means for ordering the marginal powers of all 
the carriers in the ensemble in order of increasing 
power ; 

means for assigning available power to the 
ordered marginal powers in order of increasing power; 

means for determining the value, MP (max) at 
which point the available power is exhausted; and 

means allocating power and data to each car- 
rier frequency where the power allocated is equal to 
the sum of all the marginal powers less than or equal 
to MP (max) for that carrier and the number of data units 
allocated is equal to the number of marginal powers for 
that carrier less than or equal to MP (max). 

11. The invention of claim 10 where said 
means for ordering comprises: 

means for providing a table of arbitrary mar- 
ginal power levels; and 

means for rounding the value of each determined 
marginal power level to one of the values of the table 
of arbitrary marginal power levels to decrease computa- 
tional complexity. 
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12. The invention of claim 11 wherein an A 
and B modem are connected by a telephone line and the 
means for determining equivalent noise comprises: 

5 means for establishing a communication link 

between said A and B modems; 

means for accumulating line noise data during 
a no transmission time interval at said A and B modems; 

means for transmitting a first ensemble of 
10 frequency carriers from said A modem to said B modem, 

where the amplitude of each carrier has a predetermined 
value; 

means for receiving said first ensemble at 
said B modem; 

15 means for measuring the amplitude of each 

carrier received at said B modem; 

means for comparing the measured amplitudes 
at said B modem with said predetermined amplitudes to 
determine signal loss at each carrier frequency; 

20 means for determining the value of the compo- 

nent, in dB, at each carrier frequency of the accumulated 
noise; and 

means for adding the signal loss at each car- 
rier frequency to the noise component at each carrier 
25 frequency to determine equivalent noise. 

13. In a high speed modem, for transmitting 
data in the form of a QAM ensemble of carrier frequencies 
on a VF telephone line, of the type that measures the 
magnitude of a system parameter prior to transmission, 

30 a system for tracking deviations in the magnitude of 
the system parameter during the receipt of data, said 
system comprising: 

means for generating QAM constellations for a 
plurality of carrier frequencies; 

35 means for constructing a demodulation template 

for one of said plurality of carrier frequencies com- 
prising a plurality of first regions with one of the 
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points of said constellation positioned within each of 
said first regions; 

means for forming a set of tracking regions 
where each first region has a first and second tracking 
region disposed therein; 

means for demodulating said ensemble of car- 
riers to obtain the modulation points positioned in 
said set of first and second tracking regions; 

means for counting the number of points dis- 
posed in said set of first tracking regions and the 
number of points disposed in said set of second tracking 
regions ; 

means for determining the difference in the 
number of counts disposed in said set of first tracking 
regions and disposed in said tracking regions to con- 
struct an error characteristic; and 

means for utilizing said error characteristic 
to adjust the magnitude of said signal parameter during 
the receipt of data* 

14. The invention of claim 13 wherein said 
means for constructing a demodulation template comprises: 

means for constraining said first regions to 
be in the shape of squares having said constellation 
25 points centered therein. 

15. The invention of claim 14 wherein said 
means for forming said tracking regions comprises: 

means for dividing said squares into quadrants; 

and 

30 means for selecting said tracking regions to 

be symmetrically disposed quadrants. 

16. In a communication system of the type 
including two modems (A and B) coupled by a transmis- 
sion link, each modem having an input buffer for storing 

35 data to be transmitted, a system for allocating control 
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of the transmission link between modem A and B compris- 
ing: 

means for allocating control of the trans - 
5 mission link to modem A; 

means for determining the number, K, of 
packets of data required to transmit the volume of data 
stored in the input buffer of modem A; 

means for transmitting L packets of data 
10 from modem A to modem B where L is equal to I if K is 
less than I A but less than N A , where L is equal to K if 
K is greater than or equal to I A , and where L is equal 
to N A if K is greater than N A so that the minimum number 
of packets transmitted is I A and the maximum is N A ; 
15 means for allocating control of the trans- 

mission link to modem B; 

means for determining the volume of data 
in the input buffer of modem B; 

means for determining the number, J, of 
20 packets of data required to transmit the volume of data 
stored in the input buffer of modem B; 

means for transmitting M packets of data 
from modem B to modem A where M is equal to 1^ if J is 



25 



less than I B , where M is equal to J if J is greater than 
or equal to I fi but less than N^, and where L is equal to 
N B if J is greater than N B so that the minimum number of 
packets transmitted is I_ and the maximum is NL ; 

where allocation of control between modem 
A and B is dependent on the volume of data stored in the 
30 input buffers of modems A and B. 



17* In a high speed modem communication sys- 
tem including two modems (A and B) coupled by a transmis- 
sion link, each modem having an input buffer for storing 
data to be transmitted, each modem for transmitting 
35 data over a telephone line and each modem of the type 
that encodes data elements on an ensemble of carrier 
frequencies, a method of operating said modems to effi- 
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ciently allocate power and data to the carrier frequen- 
cies, to compensate for frequency dependent phase delay, 
where the maximum estimated magnitude of the phase delay 
5 is T PH' to P revent intersymbol interference, to allocate 
control of the transmission link between modem A and 
modem B and for initiating a sampling interval having a 
given time sample offset equal to the reciprocal of the 
sampling frequency, said method comprising: 
10 determining the equivalent noise component 

for every carrier frequency in the ensemble; 

determining the marginal power requirement to 
increase the complexity of the data element on each 
carrier from n information units to n + 1 information 
15 units, n being an integer between 0 and N; 

ordering the marginal powers of all the car- 
riers in the ensemble in order of increasing power; 

assigning available power to the ordered mar- 
ginal powers in order of increasing power; 
20 determining the value, MP (max) at which point 

the available power is exhausted; 

allocating power and data to each carrier 
frequency where the power allocated is equal to the sum 
of all the marginal powers less than or equal to MP (max) 
25 for that carrier and the number of data units allocated 
is equal to the number of marginal powers for that car- 
rier less than or equal to MP(max); 

transmitting a symbol encoded on one of said 
carrier frequencies where said symbol is a predetermined 
30 time duration, T c ; 

o 

retransmitting the first T pR seconds of said 
symbol to form a transmitted waveform of duration 

T E + T PH' 

allocating control of the transmission link 
35 to modem A; 

determining the volume of data stored in the 
input buffer of modem A; 
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determining the number, K, of packets of data 
required to transmit the volume of data stored in the 
input buffer of modem A; 
5 transmitting L packets of data from modem A 

to modem B where L is equal to l A if K is less than I , 
where L is equal to K if K is greater than or equal to 

I A , and where L is equal to N A if K is greater than N A 

so that the minimum number of packets transmitted is I A 

10 and the maximum is N n ; 

A 

allocating control of the transmission link 
to modem B; 

determining the volume of data in the input 
buffer of modem B; 
15 determining the number, J, of packets of data 

required to transmit the volume of data stored in the 
input buffer of modem B; 

transmitting M packets of data from modem B 
to modem A where M is equal to I Q if J is less than 1^, 
20 where M is equal to J if J is greater than or equal to 

I B , and where L is equal to N B if J is greater than N B 
so that the minimum number of packets transmitted is I_ 

B 

and the maximum is N^; 

where allocation of control between modem A 
25 and B is dependent on the volume of data stored in the 
input buffers of modems A and B; 

generating an analog waveform at modem A in- 
cluding first and second frequency components at and 

X 2' 

30 transmitting said waveform from modem A to 

modem B at time T A ; 

adjusting the phases of said first and and 
second frequency components so that their relative phase 
difference at time T A is equal to about 0°; 

35 detecting energy at frequency at modem B 

to determine the estimated time, T EgT , that said wave- 
form arrives at modem B; 
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determining the relative phase difference at 
modem B between said first and second frequency com- 
ponents at time ^ EST 7 
5 calculating the number of sampling time off- 

sets, N r , required for the relative phase of said first 
and second carriers to change from 0 to said relative 
phase difference; and 

changing the magnitude of T EST by U J sampling 
10 intervals to obtain a precise timing reference, T n . 
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